<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  

  
  <title>Hexo</title>
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  <meta property="og:type" content="website">
<meta property="og:title" content="Hexo">
<meta property="og:url" content="http://example.com/page/2/index.html">
<meta property="og:site_name" content="Hexo">
<meta property="og:locale" content="en_US">
<meta property="article:author" content="John Doe">
<meta name="twitter:card" content="summary">
  
    <link rel="alternate" href="/atom.xml" title="Hexo" type="application/atom+xml">
  
  
    <link rel="icon" href="/favicon.png">
  
  
    <link href="//fonts.googleapis.com/css?family=Source+Code+Pro" rel="stylesheet" type="text/css">
  
  
<link rel="stylesheet" href="/css/style.css">

<meta name="generator" content="Hexo 5.4.0"></head>

<body>
  <div id="container">
    <div id="wrap">
      <header id="header">
  <div id="banner"></div>
  <div id="header-outer" class="outer">
    <div id="header-title" class="inner">
      <h1 id="logo-wrap">
        <a href="/" id="logo">Hexo</a>
      </h1>
      
    </div>
    <div id="header-inner" class="inner">
      <nav id="main-nav">
        <a id="main-nav-toggle" class="nav-icon"></a>
        
          <a class="main-nav-link" href="/">Home</a>
        
          <a class="main-nav-link" href="/archives">Archives</a>
        
      </nav>
      <nav id="sub-nav">
        
          <a id="nav-rss-link" class="nav-icon" href="/atom.xml" title="RSS Feed"></a>
        
        <a id="nav-search-btn" class="nav-icon" title="Search"></a>
      </nav>
      <div id="search-form-wrap">
        <form action="//google.com/search" method="get" accept-charset="UTF-8" class="search-form"><input type="search" name="q" class="search-form-input" placeholder="Search"><button type="submit" class="search-form-submit">&#xF002;</button><input type="hidden" name="sitesearch" value="http://example.com"></form>
      </div>
    </div>
  </div>
</header>
      <div class="outer">
        <section id="main">
  
    <article id="post-懒加载" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/%E6%87%92%E5%8A%A0%E8%BD%BD/" class="article-date">
  <time datetime="2021-07-18T02:48:04.288Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        
      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/%E6%87%92%E5%8A%A0%E8%BD%BD/" data-id="ckr8lt4sh000p20qw367shxlp" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-跨域" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/%E8%B7%A8%E5%9F%9F/" class="article-date">
  <time datetime="2021-07-18T02:48:04.284Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        
      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/%E8%B7%A8%E5%9F%9F/" data-id="ckr8lt4sm000w20qwa3hyaj06" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-架构MVVM" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/%E6%9E%B6%E6%9E%84MVVM/" class="article-date">
  <time datetime="2021-07-18T02:48:04.279Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        
      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/%E6%9E%B6%E6%9E%84MVVM/" data-id="ckr8lt4sk000u20qw2a2s9hqv" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-过滤器" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/%E8%BF%87%E6%BB%A4%E5%99%A8/" class="article-date">
  <time datetime="2021-07-18T02:48:04.276Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        <h2 id="定义和使用过滤器"><a href="#定义和使用过滤器" class="headerlink" title="定义和使用过滤器"></a>定义和使用过滤器</h2><p>使用Vue,可以有两种不同的方式注册过滤器：<strong>全局和本地过滤器</strong>。</p>
<ol>
<li><p>在某一个<code>template</code>里面定义<code>filter</code>）过滤器。</p>
</li>
<li><p>定义全局（<code>global</code>）过滤器。</p>
<p>定义一个全局过滤器，它必须在Vue实列之前定义</p>
<p>将传递<code>value</code>作为参数。</p>
</li>
</ol>
<p>Vue.js 允许你自定义过滤器，可被用于一些常见的文本格式化。过滤器可以用在两个地方：<strong>双花括号插值和 <code>v-bind</code> 表达式</strong> 。过滤器应该被添加在 JavaScript 表达式的尾部：</p>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><span class="line">&lt;!-- 在双花括号中 --&gt;</span><br><span class="line">&#123;&#123; message | capitalize &#125;&#125;</span><br><span class="line"></span><br><span class="line">&lt;!-- 在 `v-bind` 中 --&gt;</span><br><span class="line">&lt;div v-bind:id=&quot;rawId | formatId&quot;&gt;&lt;/div&gt;</span><br></pre></td></tr></table></figure>

<p>你可以在一个组件的选项中定义本地的过滤器：</p>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br></pre></td><td class="code"><pre><span class="line">filters: &#123;</span><br><span class="line">  capitalize: function (value) &#123;</span><br><span class="line">    if (!value) return &#x27;&#x27;</span><br><span class="line">    value = value.toString()</span><br><span class="line">    return value.charAt(0).toUpperCase() + value.slice(1)</span><br><span class="line">  &#125;</span><br><span class="line">&#125;</span><br></pre></td></tr></table></figure>

<p>或者在创建 Vue 实例之前全局定义过滤器：</p>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><span class="line">Vue.filter(&#x27;capitalize&#x27;, function (value) &#123;</span><br><span class="line">  if (!value) return &#x27;&#x27;</span><br><span class="line">  value = value.toString()</span><br><span class="line">  return value.charAt(0).toUpperCase() + value.slice(1)</span><br><span class="line">&#125;)</span><br><span class="line">new Vue(&#123;</span><br><span class="line">  // ...</span><br><span class="line">&#125;)</span><br></pre></td></tr></table></figure>

<p><strong>当全局过滤器和局部过滤器重名时，会采用局部过滤器。</strong></p>
<p>下面这个例子用到了 <code>capitalize</code> 过滤器：</p>
<p>John</p>
<p>过滤器函数总接收表达式的值 (之前的操作链的结果) 作为第一个参数。在上述例子中，<code>capitalize</code> 过滤器函数将会收到 <code>message</code> 的值作为第一个参数。</p>
<p>过滤器可以串联：</p>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line">&#123;&#123; message | filterA | filterB &#125;&#125;</span><br></pre></td></tr></table></figure>

<p>在这个例子中，<code>filterA</code> 被定义为接收单个参数的过滤器函数，表达式 <code>message</code> 的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数 <code>filterB</code>，将 <code>filterA</code> 的结果传递到 <code>filterB</code> 中。</p>
<p>过滤器是 JavaScript 函数，因此可以接收参数：</p>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><span class="line">&#123;&#123; message | filterA(&#x27;arg1&#x27;, arg2) &#125;&#125;</span><br></pre></td></tr></table></figure>

<p>这里，<code>filterA</code> 被定义为接收三个参数的过滤器函数。其中 <code>message</code> 的值作为第一个参数，普通字符串 <code>&#39;arg1&#39;</code> 作为第二个参数，表达式 <code>arg2</code> 的值作为第三个参数。</p>

      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/%E8%BF%87%E6%BB%A4%E5%99%A8/" data-id="ckr8lt4so000y20qw5zujco4o" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-工程组件化" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/%E5%B7%A5%E7%A8%8B%E7%BB%84%E4%BB%B6%E5%8C%96/" class="article-date">
  <time datetime="2021-07-18T02:48:04.272Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        <p>模块：android 中的模块就是业务模块，单指业务，是按照业务对 app 进行拆分，比如说订单我们搞成一个模块，个人中心我们搞成一个模块，视频，音频这些都搞成模块，在app中的体现就是 一个个module，module 的中文意思也是模块，这不准这就是 google 对我们的暗示呢。模块化的目的时为了搭积木，随便拿几个模块module 出来就可以谁谁便便的上线一个 app，你还别说现在影子 app 的需求很旺盛，你去看看大公司的项目那个不是一堆影子工程，头条还搞出一个头条视频的马甲呢，这其实就是把视频 module 拿出来，加上一个启动页。这样的例子是比比皆是的，要不说不会组件化影子工程对你就是噩梦呢，哈哈，到时候维护那是想也别想了，代码你要搞多少份啊。</p>
<p>组件：这个一样简单啊，说穿了就是我们平时干的事，对功能的封装，这就是组件，一个功能就是一个组件，IO，数据库，网络等等这些功能都是组件，这么说你就明白了吧。既然这样那为毛线我们还要搞出来这个一个组件的概念，当然了任何事都是有其意义的，因为组件对功能代码的封装有个很高了明确的要求：一处封装，处处使用。要我们把维护性，复用性，扩展性，性能做到极致，因为这样才能真正做到一处封装，处处使用。当然组件的范围现在也是覆盖的很广的，app 中的一切都是组件，基本上我们分为：基础功能组件，通用UI组件，基础业务组件。</p>

      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/%E5%B7%A5%E7%A8%8B%E7%BB%84%E4%BB%B6%E5%8C%96/" data-id="ckr8lt4se000m20qw2zr0b5ci" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-防抖与节流" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/%E9%98%B2%E6%8A%96%E4%B8%8E%E8%8A%82%E6%B5%81/" class="article-date">
  <time datetime="2021-07-18T02:48:04.268Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        <p><strong>防抖（debounce）</strong>：在事件被触发n秒后再执行回调函数，如果在这n秒内又被触发，则重新计时。</p>
<p> <strong>应用场景</strong>：(1) 用户在输入框中连续输入一串字符后，只会在输入完后去执行最后一次的查询ajax请求，这样可以有效减少请求次数，节约请求资源；</p>
<p>(2) window的resize、scroll事件，不断地调整浏览器的窗口大小、或者滚动时会触发对应事件，防抖让其<strong>只触发一次</strong>；</p>
<ul>
<li>短信验证码</li>
<li>提交表单</li>
<li>resize 事件</li>
<li>input 事件（当然也可以用节流，实现实时关键字查找）</li>
</ul>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><span class="line">// 防抖</span><br><span class="line">var timer = null;</span><br><span class="line">function debounce () &#123;</span><br><span class="line">    clearTimeout(timer);</span><br><span class="line">    timer = setTimeout(function() &#123;</span><br><span class="line">        console.log(&#x27;防抖方法执行了&#x27;)</span><br><span class="line">    &#125;, 200)</span><br><span class="line">&#125;</span><br></pre></td></tr></table></figure>

<p>第一次 timer变量保存着这个定时器的标识符（用于关闭当前定时器），如果在200毫秒内调用多次，只会执行最后一次</p>
<p><strong>节流（throttle）</strong>：规定一个单位时间，在这个单位时间内，只能有一次触发事件的回调函数执行，如果在同一个单位时间内某事件被触发多次，只有一次能生效。</p>
<p><strong>应用场景</strong>：(1)鼠标连续不断地触发某事件（如点击），只在单位时间内只触发一次；</p>
<p>(2)在页面的无限加载场景下，需要用户在滚动页面时，每隔一段时间发一次 ajax 请求，而不是在用户停下滚动页面操作时才去请求数据；</p>
<p>(3)监听滚动事件，比如是否滑到底部自动加载更多，用throttle来判断；</p>
<ul>
<li>scroll 事件，单位时间后计算一次滚动位置</li>
<li>input 事件（上面提到过）</li>
<li>播放事件，计算进度条</li>
</ul>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br></pre></td><td class="code"><pre><span class="line">// 节流</span><br><span class="line">var canNext = true;</span><br><span class="line">function throttle () &#123;</span><br><span class="line">    if(!canNext) &#123;</span><br><span class="line">        return;</span><br><span class="line">    &#125;</span><br><span class="line"></span><br><span class="line">    canNext = false;</span><br><span class="line">    setTimeout(function () &#123;</span><br><span class="line">        console.log(&#x27;节流方法执行了&#x27;)</span><br><span class="line">        canNext = true;</span><br><span class="line">    &#125;, 200)</span><br><span class="line">&#125;;</span><br></pre></td></tr></table></figure>

<p>canNext变量作为状态记录者，当它的值为 false 时，表示上一次调用正在执行，直接跳出本次调用，直到上一次的执行完毕，把true 赋给canNext,这时如果有调用，会执行这次调用。</p>

      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/%E9%98%B2%E6%8A%96%E4%B8%8E%E8%8A%82%E6%B5%81/" data-id="ckr8lt4sp000z20qw4kg2ca2e" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-发布订阅" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/%E5%8F%91%E5%B8%83%E8%AE%A2%E9%98%85/" class="article-date">
  <time datetime="2021-07-18T02:48:04.264Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        <p>Publish Subscribe Patter</p>
<h2 id="设计模式Design-Pattern"><a href="#设计模式Design-Pattern" class="headerlink" title="设计模式Design Pattern"></a>设计模式Design Pattern</h2><h3 id="创建型模式Creational-Patterns"><a href="#创建型模式Creational-Patterns" class="headerlink" title="创建型模式Creational Patterns"></a>创建型模式Creational Patterns</h3><h3 id="结构型模式Structural-Patterns"><a href="#结构型模式Structural-Patterns" class="headerlink" title="结构型模式Structural Patterns"></a>结构型模式Structural Patterns</h3><h3 id="行为型模式Behavioral-Patterns"><a href="#行为型模式Behavioral-Patterns" class="headerlink" title="行为型模式Behavioral Patterns"></a>行为型模式Behavioral Patterns</h3><p>发布订阅模式属于行为型</p>
<p>在软件架构中，发布/订阅是一种消息范式，消息的发送者（称为发布者）不会将消息直接发送给特定的接收者（称为订阅者），而是通过消息通道广播出去，让订阅改消息主题的订阅者消费到。</p>
<p><strong>发布/订阅者模式的优点</strong><br>1.松耦合/Independence<br>发布/订阅者模式可以将众多需要通信的子系统(Subsystem)解耦，每个子系统都可以独立管理。而且即使部分子系统下线了，也不会影响系统消息的整体管理。发布/订阅者模式为应用程序提供了关注点分离。每个应用程序都可以专注于其核心功能，而消息传递基础结构负责将消息路由到每个消费者手里。</p>
<p>2.高伸缩性/Scalability ：提高了发送者的响应能力。原因是发送方(Publisher)可以快速地向输入通道发送一条消息，然后返回到其核心处理职责，而不必等待子系统处理完成。然后消息传递的基础结构负责确保把消息传递到每个订阅者(Subscriber)手里。</p>
<p>3.高可靠性/Reliability ：异步的消息传递有助于应用程序在增加的负载下继续平稳运行，并且可以更有效地处理间歇性故障。</p>
<p>4.灵活性/Flexibility ：不需要关心不同的组件是如何组合在一起的，只要他们共同遵守一份协议即可。发布/订阅者模式允许延迟处理或者按计划的处理。例如当系统负载大的时候，订阅者可以等到非高峰时间才接收消息，或者根据特定的计划处理消息。</p>
<p>5.可测试性/Testability ：通道可以被监视，消息可以作为整体集成测试策略的一部分而被检查或记录。</p>
<p>实现发布/订阅者模式需要考虑的点<br>订阅处理：订阅者可以在消息通道中订阅或者取消订阅某个话题。</p>
<p>安全：连接到任何消息通道必须受到安全策略的限制，以防止未经授权的用户或应用程序窃听。</p>
<p>内容筛选：根据每条消息的内容检查和分发消息。每个订户都可以指定其感兴趣的内容。订阅者通常只对发布者分发的消息的子集感兴趣。消息服务通常允许订户缩小以下用户接收到的消息集。</p>
<p>考虑允许订户通过通配符订阅多个主题。每个主题都有一个专用的输出通道，每个使用者都可以订阅所有相关主题。</p>
<p>双向通信：<strong>发布订阅系统中的通道被视为单向的</strong>。如果特定订户需要向发布服务器发送确认或通信状态，请考虑使用请求/回复模式。此模式使用一个通道向订阅服务器发送消息，以及一个单独的回复通道向发布服务器进行通信。</p>
<p>消息排序：使用者实例接收消息的顺序得不到保证，不反映消息的创建顺序。消除对消息处理顺序的依赖。</p>
<p>消息优先级：有些解决方案可能需要按特定顺序处理消息。优先级队列模式提供了一种确保特定消息先于其他消息传递的机制。</p>
<p>有毒信息：格式错误的消息或需要访问不可用资源的任务可能会导致服务实例失败。系统应防止此类消息返回到队列，否则可能导致系统故障。</p>
<p>消息重复：同一消息可能会发送多次。例如，发送者可能在发布消息后出现了异常，没有记录自己已经成功发送了消息，然后，发送者的新实例可能会启动并重复该消息。消息基础结构应基于消息ID实现重复消息检测和删除（也称为重复数据消除），以便最多提供一次消息传递。</p>
<p>消息过期：消息的生命周期可能有限。如果在这段时间内没有处理，它可能不再有价值，应该丢弃。发送方可以指定过期时间作为消息中数据的一部分。在决定是否执行与消息关联的业务逻辑之前，接收者可以检查此信息，以确保消息没有过期。</p>
<p>消息调度：例如，消息可能会被暂时禁止，直到特定的日期和时间才被处理。</p>
<p>何时应使用发布/订阅者模式<br>如果你的程序只有很少的订阅者，或者需要与子系统进行实时的交互，那么发布/订阅者模式是不适合的。在以下情况下可以考虑使用此模式：</p>
<p>应用程序需要向大量消费者广播信息。例如微信订阅号就是一个消费者量庞大的广播平台。应用程序需要与一个或多个独立开发的应用程序或服务通信，这些应用程序或服务可能使用不同的平台、编程语言和通信协议。<br>应用程序可以向消费者发送信息，而<em><strong>不需要消费者的实时响应</strong></em>。被集成的系统被设计为支持其数据的最终一致性模型。应用程序需要将信息传递给多个消费者，这些消费者可能具有与发送者不同的可用性要求或正常运行时间计划。例如你消息在上午发布了出去，消费者计划在下午才去处理这些消息。</p>
<p>事件监听是发布订阅模式的应用</p>

      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/%E5%8F%91%E5%B8%83%E8%AE%A2%E9%98%85/" data-id="ckr8lt4se000l20qwf1yc93iy" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-webp" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/webp/" class="article-date">
  <time datetime="2021-07-18T02:48:04.260Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        
      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/webp/" data-id="ckr8lt4sb000i20qwan602tnr" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-vue核心源码、收获" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/vue%E6%A0%B8%E5%BF%83%E6%BA%90%E7%A0%81%E3%80%81%E6%94%B6%E8%8E%B7/" class="article-date">
  <time datetime="2021-07-18T02:48:04.256Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        
      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/vue%E6%A0%B8%E5%BF%83%E6%BA%90%E7%A0%81%E3%80%81%E6%94%B6%E8%8E%B7/" data-id="ckr8lt4sb000h20qw47mufgi7" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  
    <article id="post-viewUI源码组件化" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/2021/07/18/viewUI%E6%BA%90%E7%A0%81%E7%BB%84%E4%BB%B6%E5%8C%96/" class="article-date">
  <time datetime="2021-07-18T02:48:04.251Z" itemprop="datePublished">2021-07-18</time>
</a>
    
  </div>
  <div class="article-inner">
    
    
    <div class="article-entry" itemprop="articleBody">
      
        
      
    </div>
    <footer class="article-footer">
      <a data-url="http://example.com/2021/07/18/viewUI%E6%BA%90%E7%A0%81%E7%BB%84%E4%BB%B6%E5%8C%96/" data-id="ckr8lt4sa000g20qwcgjy2nrr" class="article-share-link">Share</a>
      
      
    </footer>
  </div>
  
</article>


  


  <nav id="page-nav">
    
    <a class="extend prev" rel="prev" href="/">&amp;laquo; Prev</a><a class="page-number" href="/">1</a><span class="page-number current">2</span><a class="page-number" href="/page/3/">3</a><a class="page-number" href="/page/4/">4</a><a class="extend next" rel="next" href="/page/3/">Next &amp;raquo;</a>
  </nav>

</section>
        
          <aside id="sidebar">
  
    

  
    

  
    
  
    
  <div class="widget-wrap">
    <h3 class="widget-title">Archives</h3>
    <div class="widget">
      <ul class="archive-list"><li class="archive-list-item"><a class="archive-list-link" href="/archives/2021/07/">July 2021</a></li></ul>
    </div>
  </div>


  
    
  <div class="widget-wrap">
    <h3 class="widget-title">Recent Posts</h3>
    <div class="widget">
      <ul>
        
          <li>
            <a href="/2021/07/18/%E6%99%BA%E8%83%BD%E5%8C%96%E8%B7%A8%E7%AB%AF/">(no title)</a>
          </li>
        
          <li>
            <a href="/2021/07/18/%E5%9F%9F%E8%A7%A3%E6%9E%90/">(no title)</a>
          </li>
        
          <li>
            <a href="/2021/07/18/%E6%97%A0%E9%99%90%E7%BA%A7%E7%9B%AE%E5%BD%95%E6%A0%91/">(no title)</a>
          </li>
        
          <li>
            <a href="/2021/07/18/%E6%96%87%E5%AD%97%E5%B1%85%E4%B8%AD/">(no title)</a>
          </li>
        
          <li>
            <a href="/2021/07/18/%E5%BE%AE%E6%A0%BC%E5%BC%8F/">(no title)</a>
          </li>
        
      </ul>
    </div>
  </div>

  
</aside>
        
      </div>
      <footer id="footer">
  
  <div class="outer">
    <div id="footer-info" class="inner">
      &copy; 2021 John Doe<br>
      Powered by <a href="http://hexo.io/" target="_blank">Hexo</a>
    </div>
  </div>
</footer>
    </div>
    <nav id="mobile-nav">
  
    <a href="/" class="mobile-nav-link">Home</a>
  
    <a href="/archives" class="mobile-nav-link">Archives</a>
  
</nav>
    

<script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>


  
<link rel="stylesheet" href="/fancybox/jquery.fancybox.css">

  
<script src="/fancybox/jquery.fancybox.pack.js"></script>




<script src="/js/script.js"></script>




  </div>
</body>
</html>